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FUNCTION OBJECTS 

TECHNICAL FIELD 

The present invention relates to mapping a source object with a target object. 
5 More particularly, the invention relates to function objects, which may be used for 

defining a mapping between a source object and a target object. 

BACKGROUND OF THE INVENTION 

The internet is enabling businesses to develop new ways to facilitate efficient 
10 and automated interactions between their own internal line of business, productivity 

and knowledge management applications, the applications used by their customers 
and trading partners, and services provided by their commercial and corporate 
3 providers. The challenges associated with enabling such efficient and automated 

n interactions between applications across business boundaries in a cost effective 

? I 1 5 manner are similar to those associated with enabling them within an enterprise or 

y departmental boundary. Building business-to-business (B2B) e-commerce systems 

presents many challenges to the system architect. Often, each company involved 
stores their data and documents in formats that are different from the formats used by 
□ the other participating companies. These companies need a way to integrate what 

ii 20 tend to be vastly different systems. In addition, Internet security issues are involved 

^ in business to business data interchange. Thus, several challenges are faced by 

businesses, governments, and other entities wishing to interact via electronic 
documents and other forms of electronic commerce. 

The challenges to interaction across business boundaries include lack of a 
25 sufficiently flexible and rich universal language to specify, package, publish, and 

exchange both structured and unstructured information across application or business 
boundaries. Other difficulties include a lack of a flexible and rich universal language 
to specify, package, publish, and execute transformation rules to convert information 
from one format to the other as application and business boundaries are crossed, and a 
30 lack of middleware-neutral application level communication protocols to enable 

automated interactions across application or business boundaries. The extensible 
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Markup Language (XML), and XML-based schema languages enable businesses and 
other users to describe and exchange structured information between collaborating 
applications or business partners in a platform and middleware neutral manner. 

Domain specific standards bodies and industry initiatives have started to adopt 
XML and XML-based schema languages to specify both their vocabularies and 
content models. These schemas are becoming widely published and implemented to 
facilitate communication between both applications and businesses. Wide support of 
XML has also resulted in independent solution providers developing solutions that 
enable the exchange of XML-based information with other external third party or 
custom developed applications. Several solution or middleware/platform specific 
approaches have been taken to address the lack of middleware-neutral application 
level communication protocols. 

However, no single proprietary solution or middleware platform meets all the 
needs of a complex deployment environment. In addition, the cost and complexity of 
integrating together enterprise resource planning (ERP) systems, inventory 
management systems, or sales tracking systems within a single organization strains 
the capabilities of most large and small companies alike. In the near future, electronic 
commerce is going to require massive amounts of application integration across 
multiple organizations, as trading partners turn to the Internet to automate supply 
chains, forecasting systems, government services, and new types of business 
interchanges. 

Although XML provides a standardized format for document definition, 
conventional development tools require system developers to create code for mapping 
individual source document schemas with target schemas in order to facilitate the 
interchange of information between business organizations or entities. In a typical 
example, two companies may create schemas for their documents in XML. Where 
these companies want to exchange information via internal documents, an XML 
schema is created for documents at each company, and a system developer generates 
code for mapping information transfer between the source and target document 
schemas. Such mapping code may be developed in a language such as extensible 
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Stylesheet Language (XSL). A developer may thus create an XSL style sheet 
representation of a mapping between source and target schemas. 

An XSL style sheet is a form of mapping which includes a template of the 
desired target structure, and identifies data in the source document to insert into this 
template. This model for merging data and templates is referred to as the template- 
driven model and works well on regular and repetitive data. XSL also provides 
capabilities for handling highly irregular and recursive data such as is typical in 
documents. Template fragments are defined, and the XSL processor combines the 
results of these fragments into a final result tree based on the shape of the source data. 
Each template fragment declares the type and context of source nodes it is appropriate 
for, allowing the XSL processor to match source nodes with template fragments. 
This model is known as the data-driven model since the shape of the data drives the 
shape of the final output. An XSL transformation process is thus independent of any 
particular output grammar and can be used for translating XML data from one 
schema (source) to another (target). 

Heretofore, system developers have provided code defining the 
interrelationships between XML business documents, based on the desired 
information to be exchanged via electronic commerce applications. However, for 
each source and target document set, code must be written mapping the relationships 
therebetween. Whether the code representing such a mapping is written in XSL or 
another language, writing this code is difficult and typically beyond the capabilities of 
ordinary business personnel Conventional mapping development tools require a user 
to program document schema mappings using specialized, often proprietary, 
programming languages. The complexity of such programming languages and the 
learning curve associated therewith has heretofore discouraged average business 
personnel from attempting to create document mappings without the aid of 
experienced programmers. Improved tools are thus desirable to enable business 
personnel to define document mappings for business to business applications, as well 
as to generate mapping code, which do not require extensive knowledge of software 
programming. 
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SUMMARY OF THE INVENTION 

The invention provides methods and tools for graphically creating a mapping 
which overcome or minimize the above referenced shortcomings. In addition, the 
invention includes functoids or function objects, which are elemental units of 
functional transformation. The function object generically abstracts the concept of a 
function call, used as an object. This advantageously raises the status of a function 
call to the level of an object, thereby rendering the function call a primary citizen of 
an object-oriented language. The functoids or function objects may implement any 
number of related or unrelated functions via an interface component, and further 
represent a script . 

These function objects or functoids may be graphically linked between a 
source object and a target object in a graphical user interface of a mapping tool. In 
addition to use in association with mapping tools, however, function objects may be 
advantageously employed in many applications. A function object includes a script 
component adapted to perform a function, a graphical component allowing a user to 
use the function object in association with a graphical user interface, for example, in 
creating a mapping in a mapping tool graphical user interface. In addition, function 
objects may include an interface component providing access to the script and 
graphical components. The invention further comprises methodologies and tools for 
creating such a mapping using one or more function objects. In addition, the 
invention provides a method and tool for creating a function object. 

The function object abstracts function calls to functions that may be used to 
define a mapping between the source and target objects or schemas (e.g., a COM or 
other type object). A mapping tool may provide pre-defined function objects as well 
as support for custom or user-defined function objects. The function objects may be 
represented in such a mapping tool user interface as graphical objects in a mapping 
region of a display device, which may be associated or linked with source or target 
schema tree nodes and/or other function objects in order to provide the desired 
mapping functionality. Thus, in one application, the function objects form the basis 
for the representation of elemental units of transformation, which may be embedded 
into a document mapping. A compiler in the mapping tool may be used to generate 
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output code, such as an XSL style sheet representation of the mapping, which 
includes the script component from the function objects used in defining the mapping. 
The compiled output code may then be used in translating source documents into 
target documents at runtime. 
5 The function objects may implement an interface IFunctoid, which defines a 

generic protocol for calling any number of functions implemented by the function 
object. The IFunctoid interface may be, for example, a COM or other type interface. 
Several categories of these function objects may be implemented including 
mathematical, logical, date, conversion, scientific, and advanced. In addition, users 
1 0 may define their own custom function objects in accordance with the invention, thus 

providing extensibility. The mapping tool may further create a wrapper or container 
object for every function object, which supports the function object functionality as 

0 well as other object functionality, such as the IDropSource and IDataObject 
interfaces, whereby the function object graphical component may be dragged and 

U J 5 dropped on a grid or mapping region in the mapping tool user interface, 

j y In the user interface of a mapping tool, for example, a user may select a 

desired function object graphical component from a function object palette. The 

1 graphical components placed on the mapping screen region or grid of such a 
5 graphical user interface may then be modified, moved, deleted, copied, and/or 
'720 connected with tree nodes and/or other function objects in order to create a desired 
0 mapping between a source tree and a target tree. The invention thus provides a 

significant improvement over existing mapping development tools and 

methodologies, which required a user to implement mapping code programs in 

sometimes complicated programming languages. The function objects or functoids 
25 provide an extensible mechanism by which complex mappings may be expeditiously 

created by graphically associating source and target object nodes via simple links and 

function object graphical components. 

The function objects include a script element having computer-executable 

instructions for performing a function, which may be advantageously used by a 
30 compiler to generate mapping or other type output code. In this regard, the script 

component of a function object may be employed by a mapping tool compiler in 
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association with mapping a source object with a target object. For example, the script 
associated with a function object graphical component in a mapping may be 
embedded by a mapping tool compiler into output code associated with the mapping. 
The script may be, for example, basic, visual basic, VB script, C++, visual C++, java, 

5 java script, Perl, or any scripting language. A function object in a mapping takes 

parameters from various fields in a source schema tree (or from other function 
objects) and operates on the parameters to generate an output parameter. A user may 
modify the parameters associated with a function object and may create custom 
function objects. In addition, a user may modify the script associated with a function 

10 object 



User-defined function objects may be created from scratch or by modifying 
existing function object parameters and script. The mapping tool may provide 
prompting or wizards to aid unsophisticated users in defining custom function 
objects, whereby the tool may construct the script component according to the desired 
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functionality, and may further implement the interface {e.g., a COM or other type 
interface IFunctoid). In addition, the user may consult an Internet website from the 
mapping tool interface to access a library of function objects. The invention further 
comprises computer-readable media having computer-executable instructions for 
performing the various methodologies of the invention. 



%20 



25 



30 



In accordance with one aspect of the present invention, there is provided a 
function object for use in creating a mapping between a source object having a source 
object node and a target object having a target object node in a mapping tool with a 
graphical user interface. The function object comprises a script component having 
computer-executable instructions for performing a function. The script may be, for 
example, in basic, visual basic, VB script, C++, visual C++, java, java script, Perl, or 
any scripting language. The function may be of any type, for example, mathematical, 
string operations, logical, conversion, scientific, and conversion, to provide the user 
with a wide variety of choices in creating a mapping. The function object further 
includes a graphical component associated with the function, having an input and an 
output, and adapted to allow a user to graphically associate the input with a source 
object node and to associate the output with a target object node in the graphical user 
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interface. The graphical component allows easy manipulation of the function object 
in a graphical user interface mapping design environment, whereby links to and from 
the function objects may be created. In addition, the function object includes an 
interface component having a globally unique identifier and adapted to provide the 
5 script component to a compiler in the mapping tool and to provide the graphical 

component to the graphical user interface. 

According to another aspect of the invention, there is provided a method of 
creating a mapping between a source object having a source object node and a target 
object having a target object node. The method includes providing a function object 
10 having a script component with computer-executable instructions for performing a 

function, a graphical component associated with the function with an input and an 
output, and an interface component, and displaying the graphical component in the 

O user interface of a mapping tool. The function object may by displayed in a palette 

from which the user can drag and drop the graphical component onto a mapping 

01 5 screen region of the mapping tool user interface. 

y The method further includes graphically associating a source object node with 

^ the input using a user interface selection device, graphically associating a target 

* object node with the output using the user interface selection device, and creating a 

j| mapping including the computer-executable instructions. The mapping may be 

\20 operative to perform the function according to the source object node, and to provide 

O an output value associated with the target object node according to the function. 

According to yet another aspect of the invention, a mapping tool is provided 
with a graphical user interface for creating a mapping between a source object having 
a source object node and a target object having a target object node. The mapping 
25 tool comprises means for providing a function object having a script component with 

computer-executable instructions for performing a function, a graphical component 
associated with the function and having an input and an output, and an interface 
component, as well as a display device in the graphical user interface adapted to 
display the graphical component in the user interface. In addition, the tool includes a 
30 user interface selection device (e.g., a mouse) adapted to graphically associate a 

source object node with the input, and to graphically associate a target object node 
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with the output. The association may include direct links with the function object, or 
may pass through other function objects in a cascaded fashion. The tool further 
includes a compiler adapted to create a mapping including the computer-executable 
instructions, and operative to perform the function according to the source object 
5 node, and to provide an output value associated with the target object node according 

to the function. 

According to still another aspect of the invention, a method is provided for 
creating a function object for use in constructing a mapping between a source object 
and a target object. The method includes creating a script component having 
1 0 computer-executable instructions for performing a function using the user interface, 

and creating a graphical component associated with the function and having an input 
and an output. In addition, the method includes creating an interface component 
n adapted to provide the script component to a compiler in the mapping tool and to 

provide the graphical component to the graphical user interface, and associating the 
ffl5 script component, the graphical component, and the interface component. The user 

h j may be prompted for information by a function object creation tool (e.g. , via a 

wizard), which may generate the computer-executable instructions for performing the 
» function, as well as the interface component. In this way, an unsophisticated user 

; ji may easily create custom function objects for use in creating mappings. 

f 20 In accordance with yet another aspect of the invention, there is provided a 

p function object creation tool for creating a function object, which may be employed in 

the creation of a mapping between a source object and a target object. The tool 
comprises means for creating a script component having computer-executable 
instructions for performing a function using the user interface, and means for creating 
25 a graphical component associated with the function and having an input and an 

output. In addition, the tool comprises means for creating an interface component 
adapted to provide the script component to a compiler in the mapping tool and to 
provide the graphical component to the graphical user interface, as well as means for 
associating the script component, the graphical component, and the interface 
30 component. 
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To the accomplishment of the foregoing and related ends, certain illustrative 
aspects of the present invention are hereinafter described with reference to the 
attached drawing figures. The following description and the annexed drawings set 
forth in detail certain illustrative applications and aspects of the invention. These are 
indicative, however, of but a few of the various ways in which the principles of the 
invention may be employed. Other aspects, advantages and novel features of the 
invention will become apparent from the following detailed description of the 
invention when considered in conjunction with the drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The foregoing and other aspects of the invention will become apparent from 
the following detailed description of various aspects of the invention and the attached 
drawings in which: 

Fig. 1 is a schematic diagram illustrating an exemplary function object in 
accordance with an aspect of the present invention; 

Fig. 2 is a front elevation view of an exemplary mapping tool graphical user 
interface having a source screen region, a target screen region, and a mapping screen 
region for creating a mapping between a source object and a target object using 
function objects in accordance with another aspect of the invention; 

Fig. 3 is a schematic block diagram illustrating an XSL engine translating a 
source XML document into a target XML document according to an XSLT map 
created according to the invention; 

Fig. 4A is a schematic diagram illustrating an exemplary function object 
having an interface component providing a script component to a compiler and a 
graphical component to a graphical user interface according to the invention; 

Fig. 4B is a schematic diagram illustrating another exemplary function object 
having a second interface component allowing drag and drop functionality according 
to the invention; 

Fig. 4C is a schematic diagram illustrating a another exemplary function 
object having a plurality of functions associated therewith in accordance with the 
invention; 
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Fig. 5A is a front elevation view of an exemplary graphical user interface 
having a palette screen region according to the invention; 

Fig. 5B is a front elevation view of an exemplary function object palette 
screen according to another aspect of the invention; 

Fig. 5C is a front elevation view of another exemplary function object palette 
screen having a grouping of mathematical function objects; 

Fig. 5D is a front elevation view of another exemplary function object palette 
screen having a grouping of logical function objects; 

Fig. 6 A is a front elevation view of an exemplary function object graphical 
component employed in a mapping according to the invention; 

Fig. 6B is a front elevation view of a graphical user interface having a 
function object properties page region according to the invention; 

Fig. 6C is a front elevation view of an exemplary function object properties 
page according to the invention; 

Fig. 6D is a front elevation view of another exemplary function object 
properties page having computer-executable script instructions according to the 
invention; 

Fig. 7A is a front elevation view of another exemplary mapping employing 
function objects according to the invention; 

Fig. 7B is a front elevation view of a graphical user interface having an output 
code page region according to the invention; 

Fig. 7C is a front elevation view of an exemplary output code page according 
to the invention; 

Fig. 8 is a schematic diagram illustrating an exemplary system in which a 
mapping tool may obtain a function object from a variety of sources according to the 
invention; 

Fig. 9 A is a schematic diagram illustrating a system in which a function object 
may be created according to the invention; 

Fig. 9B is a schematic diagram illustrating another system in which a function 
object may be created according to the invention; 
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Fig. 9C is a schematic diagram illustrating an exemplary tool for creating a 
function object according to the invention; 

Fig. 1 OA is a flow diagram illustrating an exemplary method of creating a 
mapping in accordance with another aspect of the present invention; 

Fig. 1 OB is a flow diagram further illustrating the method of Fig. 10A; 

Fig. IOC is a flow diagram further illustrating the method of Figs. 10A and 

10B; 

Fig. 1 1 is a flow diagram illustrating an exemplary method of creating a 
function object according to another aspect of the invention; 

Fig. 12 is a flow diagram illustrating another exemplary method of creating a 
function object according to the invention; and 

Fig. 13 is a schematic diagram illustrating an exemplary operating 
environment in which various aspects of the invention may be implemented. 

DETAILED DESCRIPTION OF THE INVENTION 

The following is a detailed description of the present invention made in 
conjunction with the attached figures, wherein like reference numerals will refer to 
like elements throughout. According to the invention, function objects or functoids 
are provided, which abstract the notion of function calls as primary citizens of an 
object-oriented language, and which may be graphically linked between a source 
object and a target object. The function objects comprise a script component, and an 
interface component. In addition, the function objects may include a graphical 
component. While various aspects of the invention are illustrated hereinafter in 
conjunction with one or more mapping tools, it will be appreciated that the function 
objects or functoids of the invention are not limited to application or employment in 
association with any particular tool or application. In this regard, it will be 
appreciated that while function objects or functoids find particular utility in 
association with such tools, that function objects may be employed, used, and/or 
created separate from any such tool and/or client within the scope of the invention 
and the attached claims. 

A function object includes a script component adapted to perform a function, 
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a graphical component allowing a user to use the function object in creating a 
mapping, and an interface component providing access to the script and graphical 
components. Function objects allow unsophisticated users to graphically define and 
compile a mapping without having to create functional computer-executable script 
thus providing significant advantages over conventional methods. 

The invention further comprises methodologies and tools for creating such a 
mapping using one or more function objects. In addition, the invention provides a 
method and tool for creating a function object. Although some of the 
implementations and aspects of the invention are illustrated and described hereinafter 
with respect to source and target objects which are XML schemas, the invention finds 
application with any type of source or target objects including, for example, schemas, 
databases, spreadsheets, documents, and the like. 

In addition, while the computer-executable instructions included in the 
function object script component are illustrated in a specific scripting language, the 
invention may be applied to languages other than those illustrated and described 
herein. It will further be appreciated that the invention contemplates a computer- 
readable storage medium having computer-executable instructions for creating a 
mapping in a graphical user interface and for creating a function object. 

Referring now to the drawings, Fig. 1 illustrates an exemplary function object 
or functoid 2, for use in creating a mapping in a mapping tool with a graphical user 
interface (not shown). The function object 2 includes a script component 4 having 
computer-executable instructions 6 for performing a function (not shown). As 
described in greater detail infra, the script component may be embedded into a 
compiled output mapping by a mapping tool compiler in accordance with an aspect of 
the invention. The function object 2 further comprises a graphical component 8 
having an input 10 and an output 12. A user may associate the input 10 with a source 
object node and the output 12 with a target object node in creating a graphical 
mapping between a source object and a target object (not shown). 
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In addition, the object 2 includes an interface component 14 having a globally 
unique identifier 16. The identifier 16 allows a mapping tool to locate the object 2, 
for example, in a DLL file in a host computer memory, or in a remote website via the 
Internet. The interface object is further adapted to provide the script component 4 to 
5 a mapping tool compiler (not shown), and to provide the graphical component 8 to a 

mapping tool graphical user interface (not shown). 

Fig. 2 illustrates an exemplary mapping tool graphical user interface 20 
having a source screen region 24 adapted to display a graphical representation of a 
source object 26, a target screen region 28 adapted to display a graphical 
1 0 representation of a destination or target object 30, and a mapping screen region 42 for 

creating a mapping 44 between the source object 26 and the target object 30 in 
accordance with an aspect of the invention. The mapping 44 is created by a user via 
CI the interconnection of nodes (not numerically designated) in the source and target 

ill objects 26, 30, using links (collectively designated 46) and one or more function 

:05 object graphical components 8. The graphical components 8 are displayed in the 

U J region 42 of the user interface 20 for easy interconnection between source nodes of 

^ the source object 26 and target nodes of the target object 30. 

H ; These interconnections may be made by placing function object graphical 

\h components 8 into the mapping screen region 42, and creating the links 46 via a user 

"720 interface selection device (e.g., a mouse). Links 46 may be created directly between 

5 source and target object nodes (e.g. , link 46a), between nodes and graphical 

components 8 (e.g. , link 46b), and/or between different function object graphical 
components 8 (e.g., link 46c). The graphical components 8 are linked to nodes and/or 
to other function object graphical components via the inputs 10 and outputs 12 
25 associated therewith. While the function object graphical components 8 are 

illustrated in Fig. 2 with a single input 10 and a single output 12, it will be 
appreciated that multiple input and/or multiple output function objects are within the 
scope of the invention, and that the graphical components 8 may comprise 
corresponding graphical indicia thereof. It will be further appreciated that the 
30 association between a graphical component input 10 and a source object node, as well 

as the association between an output 12 and a target object node may be established 
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through a series of other function object graphical components 8, whereby cascaded 
mapping functionality is easily achieved. 

The source and target objects 26 and 30, respectively, may comprise XML or 
other schemas, spreadsheets, documents, databases, and/or other information or data 
sources. The user interface 20 may accordingly be adapted to display the objects 26 
and 30 in a hierarchical tree structure to allow for ease of mapping creation. Once a 
mapping (e.g., mapping 44) has been created in the mapping screen region 42, a user 
may invoke a compiler (not shown) in the mapping tool, which generates compiled 
output code which may then be used in a runtime engine to translate source 
documents into target or destination documents. The output code will advantageously 
include the computer-executable instructions 6 from the script component 4, to 
perform the function associated with the function object graphical component 8. 

Referring now to Fig. 3, an application of the invention is illustrated 
schematically, wherein a system 50 includes a source XML document 52, a target 
XML document 54, with an XSL engine 56 therebetween. The XSL engine 56 may 
comprise, for example, a computer system, which provides data transformations 
between the source XML document 52 and the target XML document 54 in 
accordance with an XSLT map 58 generated graphically in accordance with the 
invention. In this regard, the graphical user interface 20 of Fig. 2 may be used to 
create a mapping (not shown), which is then compiled into the computer executable 
instructions or codes, for example, XSLT code (e.g., map 58), and run by the engine 
56 in performing the data transformation. Although the source and target documents 
52 and 54 are illustrated as comprising XML information, the invention finds 
application with other forms of source and/or target information. Further in this 
regard, the output code may, but need not, be XSL or XSLT, whereby it will be 
appreciated that other output code languages fall within the scope of the invention. 

The function object 2 of Fig. 1 (e.g., a COM object) abstracts the concept of a 
function call for the user of a graphical mapping tool user interface (e.g., interface 
20). This allows a user to drag and drop abstracted functions (e.g. , graphical 
components 8) into the mapping screen region 42 without the need to generate the 
computer-executable instructions associated therewith. The function object 2 may 
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support any number of functions, for example by implementing a COM or other type 
interface. 

Referring now to Fig. 4 A, an exemplary function object 100 is illustrated, 
having a script component 104 with computer-executable instructions 106 for 
performing a string concatenation function. The computer-executable instructions 
106 may be, for example, basic, visual basic, VB script, C++, visual C++, java, java 
script, Perl, or any scripting language. The object 100 further comprises a graphical 
component 108 associated with the concatenation function, having an input 1 10 and 
an output 112. The input 1 10 and output 1 12 may be associated with one or more 
source object nodes 120, and one or more target object nodes 122, respectively, in a 
graphical user interface 124 via an interface component 114. The interface 
component 1 14 includes a globally unique identifier (GUID), and further provides the 
script component 104 to a compiler 126 in a mapping tool 128. The GUID 116 may 
be used to distinguish a particular function object {e.g., object 100) from other 
objects, whereby a mapping tool 128 may search for the object 100 in a function 
object source (e.g., a DLL file in a host computer or at an Internet website). 

The interface component 1 14 may further include a category identifier 
component (CATID) 130, for example, to identify the object 100 as a function object 
for use in mapping creation, as opposed to another type of object. The CATID 130 
may be, for example, EFunctoid, to indicate the interface 1 14 as providing access to 
such function object functionality. In addition, the interface component 114 may 
include a class identifier component (CLSID) 132 and a function category identifier 
component (FUNCATID) 134. The function category is associated with the function 
implemented in the computer-executable instructions 104 of the script component 
104. As described in greater detail infra, the FUNCATID 134 may be used in 
association with function objects having a plurality of functions associated therewith 
to allow selective searching and displaying of the functions and graphical components 
associated therewith. For example, the FUNCATID may comprise one or more of 
string, mathematical logical, date, conversion, scientific, advanced, and custom 
function categories. 
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Turning now to Fig. 4B, the exemplary function object 2 of Fig. 1, supporting 
the IFunctoid interface 150, may be associated or aggregated with an IDataObject 
interface 152 and the IDropSource interface 154 in a wrapper object 156. A mapping 
tool (as illustrated and described in greater detail infra) may create the wrapper object 
5 1 56 in order to allow a mapping tool graphical interface user to drag and drop the 

graphical component 8 from a function object palette (not shown) to a mapping 
screen region (e.g., region 42 of Fig. 2). Because the invention allows a user to create 
custom function objects, the mapping tool may be adapted to wrap the function 
objects (e.g., object 2) with the interfaces 152 and/or 154 at runtime. This provides 
1 0 drag and drop functionality used in the graphical user interface of a mapping tool to 

be implemented without requiring users to implement this functionality in each 
custom function object. 

Q Referring also to Fig. 4C, another exemplary function object 170 is illustrated 

[;}{ having a plurality of script components 172 including SCRIPT 1, SCRIPT 2, SCRIPT 

m 5 3, SCRIPT 4, and SCRIPT N, where N is an integer. Associated with the plurality of 

hi script components 172 is a plurality of graphical components 174. The graphical 

; ^ components 174 are individually associated with one of the plurality of script 

^; components 172. For example, graphical component 174b is associated with SCRIPT 

lJ! 2. Script components 172 are further individually associated with a plurality of 

h tl0 function category identifier components FUNCATID 1, FUNCATID 2, FUNCATID 

O 3, FUNCATID 4, and FUNCATID N in an interface component 176. For example, 

the function category identifiers may comprise one or more of string, mathematical 
logical, date, conversion, scientific, advanced, and custom function categories. 

The interface component 176 further comprises a globally unique identifier 
25 component 178. Interface component 176 may provide one or more of the plurality 

of script components 172 to a compiler 180 and the plurality of graphical components 
174 to a graphical user interface 1 82 of a mapping tool 1 84. In this way, one function 
object 170 may provide a plurality of functionality choices for a user creating a 
mapping with a mapping tool graphical user interface 182. 
30 Referring now to Figs. 5A through 5D, the exemplary mapping tool graphical 

user interface 20 of Fig. 2 is illustrating including source screen region 24, target 
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screen region 28, and mapping screen region 42. The interface 20 may further 
comprise a function object palette region 200, as well as regions 202 and 204 for 
providing information related to selected source and target nodes in regions 24 and 
28, respectively. As illustrated in Fig. 5B, an exemplary function object palette 210 
may be displayed in the function object palette region 200 of the interface 20, 
including a plurality of function object graphical components 212. According to 
another aspect of the invention, the mapping tool may be adapted to display the 
function object palette 210 in the region 200 of interface 20, display at least one of 
the plurality of function object graphical components 212 on the palette 210, and 
allow a user to drag and drop one or more of the graphical components 212 onto the 
mapping screen region 42 in creating a mapping (e.g., mapping 44 of Fig. 2). In this 
regard, the mapping tool may be further adapted to wrap function objects (e.g., 
function object 2) with other interfaces in a wrapper object (e.g., object 150 of Fig. 
4B) in order to facilitate the drag and drop functionality, as illustrated and described 
supra. 

Referring also to Figs. 5C and 5D, the function object palette region 200 may 
further include a plurality of function object palette screens organized by function 
object category (e.g., FUNCATID of Figs. 4A and 4C). Thus, a user may be 
presented with a mathematical function object palette 220 having displayed therein a 
plurality of mathematical function object graphical components 222 (e.g., where the 
associated FUNCATID is "mathematical") as shown in Fig. 5C. Further in this 
regard, the user may be presented with a logical function object palette 230 having 
displayed therein a plurality of logical function object graphical components 232 
(e.g., where the associated FUNCATID is " logical ") as shown in Fig. 5D. Many 
categories of function objects are possible within the scope of the present invention, 
for example, mathematical logical, date, conversion, scientific, advanced, and custom 
function categories. 

Referring now to Figs. 6A through 6D, another exemplary mapping 250 is 
illustrated in region 42 of the mapping tool graphical user interface 20, including the 
exemplary string concatenation function object graphical component 8. The input 10 
of the graphical component 8 is associated with two nodes in the source object 26 and 
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the output 12 is associated with a node in the target or destination object 30. The 
interface 20 may further include a function object properties page region 260 in 
which function object parameters (e.g., input associations, values, etc.) may be 
displayed on a function object parameters page 262 (Fig. 6C), and associated 
computer-executable instructions (e.g., string concatenation instructions 106) may be 
displayed in a script page 264 (Fig. 6D). The pages 262, and 264 may be further 
adapted to allow a user to modify properties and/or computer-executable instructions 
associated with a particular function object. This allows a user to create custom 
function objects by modifying existing function objects. As discussed infra, a user 
may further create custom function objects from scratch by providing function 
information to a mapping tool or other function object creation tool. 

Referring also to Figs. 7A through 7C, another exemplary mapping 270 is 
illustrated in region 42 of interface 20 5 between a source object 272 in region 24 and a 
target object 274 in region 28. The mapping 270 comprises links (not numerically 
designated) as well as function object graphical components 275a, 275b, 275c, and 
275d (collectively referred to as 275). Interface 20 may also comprise a mapping tool 
compiler component (not shown) adapted to generate compiled output code for the 
mapping 270. The interface 20 may include an output code screen region 276 for 
displaying an output code screen or page 278, as illustrated in Fig. 7C. The output 
code page 278 displays compiled output mapping code 280 including the computer- 
executable script instructions associated with the function object graphical 
components 275 in the mapping 270. 

Referring now to Figs. 8 and 2, another aspect of the invention is illustrated. 
A mapping tool application 300 having a graphical user interface (e.g., interface 20) 
is resident in a host computer 302. The mapping tool 300 is adapted to provide one or 
more function objects (e.g., function object 2 of Fig. 1) and to display the graphical 
components thereof in the user interface 20 (e.g. , via a function object palette 210 in 
region 200). A user (not shown) may create a mapping (e.g., mapping 44 of Fig. 2) in 
the interface 20 by associating source object nodes with target object nodes using 
links (e.g., links 46 of Fig. 2) and function object graphical components (e.g., 
components 8). The mapping tool 300 may further comprise a compiler (e.g., 
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compiler 180 of Fig. 4C) adapted to generate compiled output code according to the 
mapping and including computer-executable instructions from the script component 
of the function objects in the mapping. 

The host computer 302 includes a memory 304, which may contain one or 
more dynamic link library (DLL) files 306. For example, DLL file 306a in host 
computer memory 304 may include a function object 308, while DLL file 306b does 
not. In providing a function object to the graphical user interface 20, the mapping 
tool 300 may search some or all DLL files 306 in the host computer memory 304, 
identify the function object 308 in DLL file 306a, and load the object 308 into the 
mapping tool 300 for access by a user via the graphical user interface 20. The 
mapping tool may search the memory 304 in this fashion at startup according to a 
startup script (not shown) in the mapping tool application 300, or according to a user 
command (e.g., when a user opens a function object palette 210 in region 200 of 
interface 20). In this way, the mapping tool 300 provides access to all function 
objects available in the host computer 302. 

The host computer may further provide the mapping tool application with 
access to the internet 310, whereby the mapping tool 300 may access a remote 
website 312. Upon startup, or upon a user command, the mapping tool 300 may 
search the website 3 12 for DLL files including one or more function objects for use in 
creating a mapping. For example, the website 312 may include a DLL file 306c 
having a function object 314 therein. The mapping tool may then download the DLL 
file 306c or otherwise provide access to the function object 3 14 to the user interface 
20. Mapping tool 300 may further perform searches of many such websites, 
including a site address provided by the user. In this way, a user may incorporate 
function objects from various sources into a mapping in region 42 of interface 20, 
allowing the dissemination of such function objects to many users. 

Referring now to Figs. 9A through 9C, a user may provide a custom function 
object 320 to the mapping tool 300 in accordance with another aspect of the 
invention. The user may create a user-defined IFunctoid interface component 322, a 
user-defined script component 324, and a user-defined graphical component 326 to 
the mapping tool application 300, which may then be used in creating mappings via a 
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user interface 20. The mapping tool may store the custom function object 320 in a 
DLL file 328 in the host computer memory 304 5 whereby the function object 320 may 
be used in subsequent mapping creation sessions. Referring also to Fig. 9B, the 
mapping tool 300 may alternatively or additionally store the custom function object 

5 320 in a DLL file 330 at a remote website 332 via the Internet 3 1 0 or other network. 

Referring now to Fig. 9C, the invention further comprises a function object 
creation tool 350, which may, but need not be, included in the mapping tool 300. The 
tool 350 allows an unsophisticated user to provide a text file 352, including user- 
defined function information 354 and/or user-defined graphical information 356, from 

1 0 which the tool creates a function object script component 358 and/or graphical 

component 360. The tool 350 creates a function object interface component 362, and 
associates the components 358, 360, and 362 to create a user-defined function object 

0 364. The mapping component may then store the function object 364 in a DLL file 
K 328 in the memory 304 of the host computer 302, or in a DLL file on an Internet 

5 website (e.g. , DLL file 330 on website 332). 

y In this manner, a user unfamiliar with the creation of interface components 

1 % 362, script components 358 and/or graphical components 360 may easily create a 
1. function object via the creation of a text file with function and/or graphical 

5 information. While the file 352 may be a text file, other file types are possible within 

: >20 the scope of the invention. It will be appreciated that the function object creation tool 

Q 350 may reside in the mapping tool application 300 and/or at an Internet website. 

Thus, users may access a website (e.g. , where existing function objects are stored), 
and create new function objects. It will further be appreciated that users may modify 
existing function objects, for example, via function object properties pages 262 and/or 
25 264 in user interface region 260, as illustrated and described supra with respect to 

Figs. 6A through 6D. Moreover, it will be understood that the function object 
creation tool 350 may prompt a user for information relating to the function object via 
a series of prompt screens and/or a wizard (not shown). 

Referring now to Figs. 10A through 10C, an exemplary method 400 of 
30 creating a mapping between a source object and a target object is illustrated. It will 

be appreciated that the method 400 may be implemented in the systems and tools 
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described supra, and further that the method 400 may be practiced in other systems 
not illustrated. Beginning at step 402, a mapping tool (e.g., tool 300) searches a host 
computer (e.g., computer 302) for DLL files having function objects. At step 404, the 
identified DLL file (e.g., file 306a of memory 304) is loaded into the mapping tool. 
Thereafter at step 406, the tool obtains a function object (e.g., object 308) from the 
DLL file, which includes a script component, a graphical component, and an interface 
component. At step 408, the tool creates a wrapper object (e.g. , object 1 56 of Fig. 
4B) including the interface component and a second interface component adapted to 
allow the graphical component or components to be dragged and dropped in a 
mapping screen region (e.g., mapping screen region 42 of mapping tool graphical 
user interface 20). 

Continuing a step 410 of Fig. 10B, the tool then obtains a graphical 
component from the wrapper object via the interface component, and displays the 
graphical component in a function object palette (e.g., palette 210 of Fig. 5B) in a 
mapping tool graphical user interface (e.g., interface 20) at step 412. Thereafter, the 
tool allows a user to drag and drop the graphical component from the palette to a 
mapping screen region (e.g., region 44) in the graphical user interface at step 414. At 
step 416, the user is allowed to graphically associate a source object node with the 
input of the graphical component (e.g., via links 46), and at step 418, the user may 
associate a target object node with the output of the graphical component. 

At step 420 of Fig. 10C, the script component of the function object is 
provided to a mapping tool compiler via the interface component. Thereafter, at step 
422, a compiled output mapping is created (e.g., via mapping tool compiler 126 of 
Fig. 4A), including the computer-executable instructions from the function object 
script component. The output code is operative to perform the function associated 
with the graphical component according to the source object node, and to provide an 
output value associated with the target object node according to the function. The 
method 400 thus provides significant advantages over convention methodologies, 
which required a user to create custom script code for mapping source and target 
documents or objects. The present invention thus provides a rich graphical mapping 
environment in which a user may easily employ function objects without need to 



21 



MS147164.1 



understand the underlying computer-executable script instructions associated 
therewith. 

Referring now to Fig. 1 1 , an exemplary method 450 of creating a function 
object is illustrated according to another aspect of the invention. The method 450 
begins at step 452, wherein a script component is created having computer-executable 
instructions for performing a function. A graphical component is then created at step 
454, which is associated with the function and includes an input and an output (e.g., 
input 10 and output 12 of graphical component 8 of Fig. 1). Thereafter at step 456, an 
interface component (e.g., component 14) is created, which is adapted to provide the 
script component created at step 452 to a mapping tool compiler, and further to 
provide the graphical component created at step 454 to a user interface (e.g., 
graphical user interface 20). The script component, the graphical component, and the 
interface components are then associated with each other at step 458, whereby a 
function object is created in accordance with the invention. 

Turning now to Fig. 12, another exemplary method 470 of creating a function 
object is illustrated, wherein function object information is received from a user at 
step 472. At step 474, a script component is generated according to the function 
information. The script component may include computer-executable instructions for 
performing the function. A graphical component is then created at step 476 according 
to the function information received at step 472. At step 478, an interface component 
is generated according to the function information, and at step 480, the script 
component, the graphical component, and the interface component are associated. 
The user may be prompted for the function information, which prompting may be in 
the form of a function object creation wizard. 

EXEMPLARY OPERATING ENVIRONMENT 
In order to provide a context for the various aspects of the invention, Fig. 13 
and the following discussion are intended to provide a brief, general description of a 
suitable computing environment in which the various aspects of the present invention 
may be implemented. While the invention has been described above in the general 
context of computer-executable instructions of a computer program that runs on a 
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computer, those skilled in the art will recognize that the invention also may be 
implemented in combination with other program modules. Generally, program 
modules include routines, programs, components, data structures, etc. that perform 
particular tasks or implement particular abstract data types. Moreover, those skilled 
5 in the art will appreciate that the inventive methods may be practiced with other 

computer system configurations, including single-processor or multiprocessor 
computer systems, minicomputers, mainframe computers, as well as personal 
computers, hand-held computing devices, microprocessor-based or programmable 
consumer electronics, and the like. The illustrated aspects of the invention may also 
1 0 be practiced in distributed computing environments where tasks are performed by 

remote processing devices that are linked through a communications network. 
However, some, if not all aspects of the invention can be practiced on stand-alone 

O computers. In a distributed computing environment, program modules may be 

Jl located in both local and remote memory storage devices. 

| 1 5 With reference to Fig. 1 3, an exemplary system for implementing the various 

W aspects of the invention includes a conventional server computer 520, including a 

I? I processing unit 521 , a system memory 522, and a system bus 523 that couples various 

'; as system components including the system memory to the processing unit 521 . The 

*!i processing unit may be any of various commercially available processors, including 

>20 but not limited to Intel x86, Pentium and compatible microprocessors from Intel and 

9 others, including Cyrix, AMD and Nexgen; Alpha from Digital; MIPS from MIPS 

Technology, NEC, IDT, Siemens, and others; and the PowerPC from IBM and 
Motorola. Dual microprocessors and other multi-processor architectures also can be 
used as the processing unit 521 . 
25 The system bus may be any of several types of bus structure including a 

memory bus or memory controller, a peripheral bus, and a local bus using any of a 
variety of conventional bus architectures such as PCI, VESA, MicroChannel, ISA and 
EISA, to name a few. The system memory includes read only memory (ROM) 524 
and random access memory (RAM) 525. A basic input/output system (BIOS), 
30 containing the basic routines that help to transfer information between elements 

within the server computer 520, such as during start-up, is stored in ROM 524. 
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The server computer 520 further includes a hard disk drive 527, a magnetic 
disk drive 528, e.g., to read from or write to a removable disk 529, and an optical disk 
drive 530, e.g., for reading a CD-ROM disk 531 or to read from or write to other 
optical media. The hard disk drive 527, magnetic disk drive 528, and optical disk 
drive 530 are connected to the system bus 523 by a hard disk drive interface 532, a 
magnetic disk drive interface 533, and an optical drive interface 534, respectively. 
The drives and their associated computer-readable media provide nonvolatile storage 
of data, data structures, computer-executable instructions, etc. for the server computer 
520. Although the description of computer-readable media above refers to a hard 
disk, a removable magnetic disk and a CD, it will be appreciated by those skilled in 
the art that other types of media which are readable by a computer, such as magnetic 
cassettes, flash memory cards, digital video disks, Bernoulli cartridges, and the like, 
may also be used in the exemplary operating environment, and further that any such 
media may contain computer-executable instructions for performing the methods of 
the present invention. 

A number of program modules may be stored in the drives and RAM 525, 
including an operating system 535, one or more application programs 536, other 
program modules 537, and program data 538. The operating system 535 in the 
illustrated computer may be the Microsoft Windows 2000 Server operating system, 
together with the before mentioned Microsoft Transaction Server. 

A user may enter commands and information into the server computer 520 
through a keyboard 540 and a pointing device, such as a mouse 542. Other input 
devices (not shown) may include a microphone, a joystick, a game pad, a satellite 
dish, a scanner, or the like. These and other input devices are often connected to the 
processing unit 521 through a serial port interface 546 that is coupled to the system 
bus, but may be connected by other interfaces, such as a parallel port, a game port or 
a universal serial bus (USB). A monitor 547 or other type of display device is also 
connected to the system bus 523 via an interface, such as a video adapter 548. In 
addition to the monitor, computers typically include other peripheral output devices 
(not shown), such as speakers and printers. 
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The server computer 520 may operate in a networked environment using 
logical connections to one or more remote computers, such as a remote client 
computer 549. The remote computer 549 may be a workstation, a server computer, a 
router, a peer device or other common network node, and typically includes many or 
all of the elements described relative to the server computer 520, although only a 
memory storage device 550 is illustrated in Fig. 14. The logical connections depicted 
in Fig. 14 include a local area network (LAN) 55 1 and a wide area network (WAN) 
552. Such networking environments are commonplace in offices, enterprise-wide 
computer networks, intranets and the Internet. 

When used in a LAN networking environment, the server computer 520 is 
connected to the local network 551 through a network interface or adapter 553. 
When used in a WAN networking environment, the server computer 520 typically 
includes a modem 554, or is connected to a communications server on the LAN, or 
has other means for establishing communications over the wide area network 552, 
such as the Internet. The modem 554, which may be internal or external, is connected 
to the system bus 523 via the serial port interface 546. In a networked environment, 
program modules depicted relative to the server computer 520, or portions thereof, 
may be stored in the remote memory storage device. It will be appreciated that the 
network connections shown are exemplary and other means of establishing a 
communications link between the computers may be used. 

In accordance with the practices of persons skilled in the art of computer 
programming, the present invention has been described with reference to acts and 
symbolic representations of operations that are performed by a computer, such as the 
server computer 520, unless otherwise indicated. Such acts and operations are 
sometimes referred to as being computer-executed. It will be appreciated that the acts 
and symbolically represented operations include the manipulation by the processing 
unit 521 of electrical signals representing data bits which causes a resulting 
transformation or reduction of the electrical signal representation, and the 
maintenance of data bits at memory locations in the memory system (including the 
system memory 522, hard drive 527, floppy disks 529, and CD-ROM 531) to thereby 
reconfigure or otherwise alter the computer system's operation, as well as other 
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processing of signals. The memory locations where such data bits are maintained are 
physical locations that have particular electrical, magnetic, or optical properties 
corresponding to the data bits. 

Although the invention has been shown and described with respect to a certain 
implementations, it will be appreciated that equivalent alterations and modifications 
will occur to others skilled in the art upon the reading and understanding of this 
specification and the annexed drawings. In particular regard to the various functions 
performed by the above described components (assemblies, devices, circuits, systems, 
etc.), the terms (including a reference to a "means") used to describe such components 
are intended to correspond, unless otherwise indicated, to any component which 
performs the specified function of the described component {i.e., that is functionally 
equivalent), even though not structurally equivalent to the disclosed structure, which 
performs the function in the herein illustrated exemplary applications and 
implementations of the invention. In this regard, it will also be recognized that the 
invention includes a computer-readable medium having computer-executable 
instructions for performing the steps of the various methods of the invention. 

In addition, while a particular feature of the invention may have been 
disclosed with respect to only one of several aspects or implementations of the 
invention, such a feature may be combined with one or more other features of the 
other implementations as may be desired and advantageous for any given or particular 
application. Furthermore, to the extent that the terms "includes", "including", "has", 
"having", and variants thereof are used in either the detailed description or the claims, 
these terms are intended to be inclusive in a manner similar to the term "comprising" 
and its variants. 
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CLAIMS 

What is claimed is: 

1 . A function object for use in creating a mapping in a mapping tool with 
a graphical user interface, between a source object having a source object node and a 
target object having a target object node, comprising: 

a script component having computer-executable instructions for performing a 
function; 

a graphical component associated with the function, having an input and an 
output, and adapted to allow a user to graphically associate the input with a source 
object node and to associate the output with a target object node in the graphical user 
interface; and 

an interface component having a globally unique identifier and adapted to 
provide the script component to a compiler in the mapping tool and to provide the 
graphical component to the graphical user interface. 

2. The function object of claim 1, wherein the interface component 
further includes a category identifier component. 

3. The function object of claim 1, wherein the interface component 
further comprises a class identifier component. 

4. The function object of claim 1 , wherein the interface component 
further comprises a function category identifier component associated with the 
function. 

5. The function object of claim 1, wherein the function category 
identifier component includes one of string, mathematical, logical, date, conversion, 
scientific, advanced, and custom. 
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6. The function object of claim 1 , further comprising a second interface 
component adapted to allow a user to drag and drop the graphical component in the 
graphical user interface. 

7. The function object of claim 5, wherein the second interface 
component is associated with the function object by the mapping tool. 

8. The function object of claim 1 , further comprising: 

a plurality of script components having computer-executable instructions for 
performing a plurality of functions; and 

a plurality of graphical components individually associated with one of the 
plurality of functions, individually having an input and an output, and individually 
adapted to allow a user to graphically associate the input with a source object node 
and to associate the output with a target object node in the graphical user interface; 

wherein the interface component is further adapted to provide the plurality of 
script components to a compiler in the mapping tool and to provide the plurality of 
graphical components to the graphical user interface. 

9. The function object of claim 7, wherein the interface component 
further comprises a plurality of function category identifier components individually 
associated with the plurality of functions. 

10. The function object of claim 1, wherein at least one of the plurality of 
function category identifier components includes one of string, mathematical, logical, 
date, conversion, scientific, advanced, and custom. 

1 1 . The function obj ect of claim 1 0, wherein the plurality of script 
components having computer-executable instructions for performing a plurality of 
functions are in a scripting language. 
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12. The function object of claim 1 1, wherein the scripting language is one 
of java script, visual basic script, and visual C++. 

1 3 . The function object of claim 1 , wherein the script component having 
computer-executable instructions for performing the function is in a scripting 
language. 

14. The function object of claim 13, wherein the scripting language is one 
of java script, visual basic script, and visual C++. 

15. The function object of claim 1, wherein the function object is a COM 
object, and the interface component is a COM interface. 

16. In a mapping tool with a graphical user interface, a method of creating 
a mapping between a source object having a source object node and a target object 
having a target object node, the method comprising: 

providing a function object having a script component with computer- 
executable instructions for performing a function, a graphical component associated 
with the function and having an input and an output, and an interface component; 

displaying the graphical component in the user interface; 

graphically associating a source object node with the input using a user 
interface selection device; 

graphically associating a target object node with the output using the user 
interface selection device; and 

creating a mapping including the computer-executable instructions, and 
operative to perform the function according to the source object node, and to provide 
an output value associated with the target object node according to the function. 

1 7. The method of claim 1 6, wherein providing the function object further 
comprises obtaining the function object from a host computer. 
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18. The method of claim 1 7, wherein obtaining the function object from a 
host computer further comprises obtaining the function object from a DLL file in the 
host computer. 

19. The method of claim 1 8, wherein obtaining the function object from a 
DLL file in the host computer further comprises: 

searching the DLL files in the host computer; 

identifying the function object in the searched DLL files; and 

loading the function object into the mapping tool. 

20. The method of claim 1 6, wherein providing the function object further 
comprises obtaining the function object from a global communications network. 

21. The method of claim 20, wherein obtaining the function object from a 
global communications network further comprises obtaining the function object from 
an Internet web site. 

22. The method of claim 21 , wherein obtaining the function object from an 
Internet web site further comprises one of searching the Internet for the function 
object according to a mapping tool startup script, searching the Internet for the 
function object according to a user command, and searching a web site provided by 
the user for the function object. 

23 . The method of claim 1 6, further comprising: 

providing a plurality of script components with computer-executable 
instructions for performing one of a plurality of functions, a plurality of graphical 
components individually associated with one of the plurality of functions and 
individually having an input and an output, wherein the interface component is 
associated with the plurality of script components and the plurality of graphical 
components; and 
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displaying at least one of the plurality of graphical components in the user 
interface. 

24. The method of claim 16, wherein providing the function object further 
comprises creating a wrapper object in the mapping tool, including the interface 
component of the function object and a second interface component adapted to allow 
a user to drag and drop the graphical component in the graphical user interface. 

25 . The method of claim 1 6, wherein displaying the graphical component 
further comprises obtaining the graphical component from a function object source 
via the interface component. 

26. The method of claim 25, wherein the function object source is a DLL 
file on a host computer. 

27. The method of claim 25, wherein obtaining the graphical component 
from a function object source comprises obtaining the graphical component from a 
DLL file via the Internet. 

28 . The method of claim 1 6, wherein displaying the graphical component 
further comprises: 

displaying a function object palette in the graphical user interface; 
displaying the graphical component on the function object palette; and 
allowing a user to drag and drop the graphical component from the function 
object palette to a mapping screen region in the graphical user interface. 

29. The method of claim 28, further comprising: 

providing a plurality of script components with computer-executable 
instructions for performing one of a plurality of functions, a plurality of graphical 
components individually associated with one of the plurality of functions and 
individually having an input and an output, wherein the interface component is 
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associated with the plurality of script components and the plurality of graphical 
components; 

displaying a function object palette in the graphical user interface; 

displaying at least one of the plurality of graphical components on the 
function object palette; and 

allowing a user to drag and drop the at least one of the plurality of graphical 
components from the function object palette to a mapping screen region in the 
graphical user interface. 

30. The method of claim 1 6, wherein the mapping tool further comprises 
compiler component, and wherein creating the mapping further comprises: 

invoking the compiler component to generate compiled output code; and 
providing the computer-executable instructions from the script component to 
the compiler via the interface component. 

3 1 . The method of claim 1 6, wherein the mapping tool further comprises 
compiler component, and wherein creating the mapping further comprises: 

providing a plurality of script components with computer-executable 
instructions for performing one of a plurality of functions, a plurality of graphical 
components individually associated with one of the plurality of functions and 
individually having an input and an output, wherein the interface component is 
associated with the plurality of script components and the plurality of graphical 
components; 

displaying a function object palette in the graphical user interface; 

displaying at least one of the plurality of graphical components on the 
function object palette; 

allowing a user to drag and drop the at least one of the plurality of graphical 
components from the function object palette to a mapping screen region in the 
graphical user interface; 

invoking the compiler component to generate compiled output code; and 
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providing the computer-executable instructions from the plurality of script 
components to the compiler via the interface component. 

32. A mapping tool with a graphical user interface for creating a mapping 
between a source object having a source object node and a target object having a 
target object node, comprising: 

means for providing a function object having a script component with 
computer-executable instructions for performing a function, a graphical component 
associated with the function and having an input and an output, and an interface 
component; 

a display device in the graphical user interface adapted to display the 
graphical component in the user interface; 

a user interface selection device adapted to graphically associate a source 
object node with the input, and to graphically associate a target object node with the 
output; and 

a compiler adapted to create a mapping including the computer-executable 
instructions, and operative to perform the function according to the source object 
node, and to provide an output value associated with the target object node according 
to the function. 

33. In a mapping tool with a graphical user interface, a method of creating 
a function object for use in creating a mapping between a source object and a target 
object, the method comprising: 

creating a script component having computer-executable instructions for 
performing a function using the user interface; 

creating a graphical component associated with the function and having an 
input and an output; 

creating an interface component adapted to provide the script component to a 
compiler in the mapping tool and to provide the graphical component to the graphical 
user interface; and 
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associating the script component, the graphical component, and the interface 
component. 

34. The method of claim 33, wherein creating the script component further 
comprises receiving a user-defmed text file including the computer-executable 
instructions, and creating the script component using the computer-executable 
instructions from the text file. 

35. The method of claim 34, wherein the computer-executable instructions 
include one of basic, visual basic, VB script, C++, visual C++, Java, java script, and 
Perl. 

36. The method of claim 33, wherein creating the script component 
comprises receiving function information from a user, and creating the computer- 
executable instructions based on the function information. 

37. The method of claim 33, wherein creating the interface component 
comprises: 

receiving a text file from a user, wherein the text file includes information 
related to the function; and 

creating the interface component according to the information in the text file. 

38. The method of claim 37, wherein the information related to the 
function is in XML. 

39. The method of claim 33, further comprising: 
prompting a user for information related to the function object; 

receiving prompted information from the user via the graphical user interface; 
creating the script component having computer-executable instructions for 
performing a function using the prompted information; and 
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creating the graphical component associated with the function and having an 
input and an output using the prompted information. 

40. The method of claim 39, wherein prompting a user for information 
related to the function object comprises providing a wizard in the graphical user 
interface. 

41 . A function object creation tool for creating a function object for use in 
creating a mapping in a mapping tool between a source object and a target object, the 
function object creation tool comprising: 

means for creating a script component having computer-executable 
instructions for performing a function using the user interface; 

means for creating a graphical component associated with the function and 
having an input and an output; 

means for creating an interface component adapted to provide the script 
component to a compiler in the mapping tool and to provide the graphical component 
to the graphical user interface; and 

means for associating the script component, the graphical component, and the 
interface component. 

42. A computer-readable medium having computer-executable 
instructions for performing the following steps: 

providing a function object having a script component with computer- 
executable instructions for performing a function, a graphical component associated 
with the function and having an input and an output, and an interface component; 

displaying the graphical component in a user interface; 

graphically associating a source object node with the input using a user 
interface selection device; 

graphically associating a target object node with the output using the user 
interface selection device; and 
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creating a mapping including the computer-executable instructions, and 
operative to perform the function according to the source object node, and to provide 
an output value associated with the target object node according to the function. 

43. A computer-readable medium having computer-executable 
instructions for performing the following steps: 

creating a script component having computer-executable instructions for 
performing a function; 

creating a graphical component associated with the function and having an 
input and an output; 

creating an interface component adapted to provide the script component to a 
compiler in a mapping tool and to provide the graphical component to a graphical 
user interface; and 

associating the script component, the graphical component, and the interface 
component. 

44. A function object for use in creating a mapping, between a source 
object having a source object node and a target object having a target object node, 
comprising: 

a script component having computer-executable instructions for performing a 
function; 

a graphical component associated with the function, having an input and an 
output, and adapted to allow a user to graphically associate the input with a source 
object node and to associate the output with a target object node; and 

an interface component having a globally unique identifier and adapted to 
provide the script component to a compiler and to provide the graphical component to 
a graphical user interface. 

45. A computer-readable medium having computer-executable 
instructions for performing the following steps: 
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creating a script component having computer-executable instructions for 
performing a function; 

creating a graphical component associated with the function and having an 
input and an output; 

creating an interface component adapted to provide the script component to a 
compiler and to provide the graphical component to a graphical user interface; and 

associating the script component, the graphical component, and the interface 
component. 
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ABSTRACT OF THE INVENTION 

Methods and tools are provided for graphically creating a mapping between a 
source object and a target object. The invention includes function objects or 
functoids, which may be graphically linked between a source object and a target 
5 object in a graphical user interface of a mapping tool. The function objects include a 

script component adapted to perform a function, a graphical component allowing a 
user to use the function object in creating a mapping in a mapping tool graphical user 
interface, and an interface component providing access to the script and graphical 
components. The invention further comprises methodologies and tools for creating 
10 such a mapping using one or more of the function objects, as well as a method and 

tool for creating function objects. 



38 



CM 



CM 




CD 

LL 





I 00 
CM 



UJ ! 








Q 








TERFAC 


GUID 


CATID 


CLSID 


UNCATI 1 








Z ; 








LL 


























CM 
CO 



CO 



J 



CM 




< 

O 

LL 



J 



CO 



CM 

in 




CO 

O 
u. 




I <£> 



LU 
SO 

c * 

Li. H 



A 


t 


i 


L 


i 




_L 




CM 


CO 






z 


1- 




1- 


1- 






Ql 






D_ 




CL 


DC 


a: 


en 


a: 




a: 


O 


0 


0 


0 




0 


CO 


CO 


0 


0 


0 


0 




CO 



a n n a 



CM 



>- q: 

_J LU LU 

m O h 

SIS 

CD Q 



00 



TTTTTTTTT 



1^ 




o 



o 




CM 



E 



(0 
<D 

t 

a 
o 

Q. 

O 

c 



S2 

o 
E 

w 
(0 
Q. 

3 

a 




CM 
CM 



CD 
O 

c 

CD 

o 



O 



£ 

E 

x 

05 

E 

o 
c 

</> 

0 

0 



0 

-I— » 

0 

i 12 

CO £ 
Q. 0 

^ E 

^ CO 

8 I 

CD Q- 
— 

CO Q. 

0 .E 

> 14- 

i| 

"O 0 

1! 

CO +i 

F E 



V 



o 

O 

LL 



o 

m 
m 
ru 
la 

a 
,p 

O 

a 



0 



CO 

a> 

a 

2 

Q. 

5 

O 
£ 

LL 



O 




O 
CO 

■o 

"5 

o 
c 

3 




CO 
CM 



v 



a) 

o 
c 

CO 

O 



O 



a 

CO 

o 

LL 




CM 



00 
CM 



v 



CM 



v 



r CM CO CM ^ 

Q Q Q Q Q Q Q 

rv i — i — ' r£ — ' — ' 

q LU LU LU q LU LU 




CM 
CM 



CM 



< 

O 

UL 



CM 



CO 
CM 



X 
ii 

_c 

o 

CO 

E 

CD 
1 

E 



V V V 



A 



CM 

jD 

0 

Ll 

■| A 
tO +i 



2 £ 

.0) CD 

1)1 

^ V 



to > 

p 

< ~\\ 

^ 0) 

o CO 

^ ? 

0) 0) 



CD 

> 
c 



to 

^ A 
CO 0 

0 ^ 

Li. " 



_3 
CO 

> 



■§ 3 

SX 
cm :> 

>*CN 
Q. > 

I > 

CO o 

^ *> 

=^ 0 

o CO 

t ? 

0 0) 

■ii 5 



8 8 



X 
V 
A 



CO 
X 
V 
A 



O 
O 
0 
C£ 
"ll 

"5 

0 A 

0 £ 
CO £ 

_c o 

CO $ 
0 Ct 

iL V 

o 



^- CD 

> 2 

^ 0 

0 0 

E | 

co 2 

c c 

0 £> 

_Q 3 

CO -Q 



CM 

> 2 

is .32 

II H> 

E E 

co 5 

0 a) 

CO -Q 



CO *S CO 
> CO > 



CO 



_r; r: r. r- A 
co co co co co 



X 
V 



X 
V 



X "O 

v 5 

o 

0 

X. 



A 
CM 
*g 

O 
O 
0 

Ql 

ll 

t> 

0 
co 



■*S co 

(O ^ 

0 

"O U- 

.3>@A 



^ o 

2 0 

8* 
0 p 

9= F 



LO 

0 



0 

Ll 

C 



CO 

0 
o 

CO c 
0 CO 

co .E 

C CM 
CO 

sf 

< s 



D) 

■E A 
0 
CO ' 



n += 0 



_c x: -c 

CO CO 



CO S 

fx 

of l: 

"D CO 

> £ 



co (D 



o o 



£ 0 



Si 
g>i/i 
■I £ 

£ X 

CM :> 
CO £ 

I > 

£ 0 

o CO 



0 0 0 

CO CO CO 

D 3 3 

"ll "ll "ll 

^— » ^— » -t— » 

o o o 

0 0 0 

0 0 0 

CO CO CO 

CO LO 

> > > 

L_! LJ LJ 

CO CO CO 

> > _> 

II Ii 

0 0 

E E 

CO CO CO 

c c c 



0 0 0 

_g ^ ^ 

co -„ co 

> ii > 

V 0 

A CO 



CO 
X 
V 
A 



II 
0 

E 



0 0 0 

-Q -Q -Q 
CO CO CO 

CO CO CO 

>>>.... 

A /A /A /A //\ ff\ 



A 

o 

CO 

0 

CO 7n 

v* CO 

< X 

V V 



o 
o 
0 
a: 

V 



CO to CO 
XXX 
V V V 



CO CD O) 

2 > 2 
0^0 

Ii "ii "ii 

0 <D 0 

E E E 

a> 0 0 
■9 co -9 

's— "i— 

CO & 

v±v A 

CO CO CO 



X X 
V V 



X "O 

V " 



o 



s s 



V 



en 

LU 
I- 

3 >- 

a. q; 
^ o 
o s 
o uj 
i— s 

CO 

o 

X 



HI 



Q 



Z T- 

g h 

I— q 

2 O 



O 

CO 



\ \ 


m 


00 


CO 


o 


o 


CO 


CO 





CM 
Hi 



& 

m 
m 
ry 
w 
$ 

si 

a 

=|: 

a 
a 




O 
CO 



00 

O 



CM 
CO 



a 
o 

CO 



T- 

co 



LU 

CO 
OQ 
UJ 

UJ 

I- 

O 

LU 

a: 



CO 


Z CN 




UJ 


Qh 




-J 


h- o 




LL 


o UJ 




1 






— 1 
Q 






< 







LU 






1- 






W 






m 


LU 




LU 


_J 






Li- 




OTE 


DLL 










LU 














i 



CM 
CO 
CO 




CQ 

CD 
u_ 



O 



o 



Q 

CC 

O 
u. 

Li c/3 

1 o 
uj yj 

z 5 

z 

Q o 

Q h- 
Z O 

< z 

lu 
i- 

D 
Q. 



O 
O 

I- 
W 

o 

X 
X 

o 
< 

LU 
CO 



(3 
z 

X 

w 

LU 



O 
O 

I- 

o 
z 

Q. 
Q_ 

< 

O 
I- 

z 

LU 
_J 

u_ 

_l 
_l 
Q 

Q 
< 

o 




O 

o 



CM 



0£ 
LU 
CL 

a. 

2 



LU 
Z 

o 

CL 



LU 



LU 

!2 



o 
cm 

LL 



o 
a 

LU 

o 
< 

LL 
CC 

111 
h- 

Z 

8 w 



s 

X 

a. 

CD 
< 



CO 

O 



< 
> 
I- 
o 

111 
CO 

O 



g 
o 



cm 

111 

co 

D 
_l 
< 

o 

X 
Q_ 
< 

01 
CD 



^6 
Sgui 

O ? ^ 



° 8- 

0 ^ 

1 < 

Q_ 



CO 



LL 

o: 

LU 
I- 



LU 
CDH 

LU LU 
I _J 

H 
O 
LU 



CO 
O 



< 

O 

X 
CL 
< 

o 

111 
X 
H 

CL 

o 

a: 

Q 

< 



LU 
LU 

&LU 

CO Q 

CD < 

z " 



CL 
0. 
< 

< 

o 
h- 

LU 
H 
I— 
LU 
_l 
< 
CL 

Q x 

O 1 " 
l- 2 

a: O 
lu cm 

CO LL 

< 



q: 
lu 
h- 
z 

a: 
lu 

CO 

_l 
< 
O 

X 
0. 



o 

CL 

o 
o 



CD 
LU 
X 
H 



LU O 



LU 

DC 



CO 

5 



^< ll 



o 
o 

CO 
CO 

< 



5 



LU 
X 



o 
z> 

CL 



>- - 



LU LU 

X z 



X 
H 



X 
Q_ 

CD 
O 

h- Z 

a: i- 

LU O 
CO LU 



LU 

a 

o 



o 

CL 

o 
o 

< 
o 

X 
CL 



~3 

CD 

o 

LU 
O 

cm 
o 

CO 



CD 



00 

T" 



H 
LU 

o ^ 

w cm 
£o 

° E 

co : 

CO U. 

< o 
>■ 1 1- 

-I id z 

X O CL 
CL LU 2 

x o 
o 



2 

CD 



O H 

£5 

LU LU 
CO Q 
Z) O 



LU 
X 

I- 



I- 
o 

LU 
CO 

O 



O 
o 



CD 



O 




CO 
o 

d 

LL 



O 

o 



CO 

o 



O 

LL 

o 



GO 



O 
CM 



o 
o 

=: LU 




CL 
CL 
< 

< 

O 
H 

H 
Z 
LU 
Z 

o 

Q_ 



o 

Q_ 

o 
o 

LU 

o 
< 

cc 

LU 
H 



O 

o 



LU 
X 

_ < 

o: > 
o a; 



Q_ 



LU 



CO 

LU 
I 
h- 

98 
g 

a: 




CM 



Q 
Z 

LU 



o 

o 

o 

u. 



O 

o 



CM 

m 























COMP 
FORMI 






CD 01 






Z LU 






> Q - 






< £ 






x O 












Z CO o 

UJ Z r- 










iMPON 
UCTIO 
FUNCT 






o a: 






O h- 






h- » 

£L ? 






LU 






Q -1 






CO 9 






<£ 




Y'"i 


LU Z> 






H O 






< LU 






LU X 






01 LU 






o 






00 





_J 




< 




1— 




x z 




Q_ LU 








S § 




O Q. 




LU2 




I o 




1- O 




|— " LU 




z o 




LU < 




TE THE SCRIPT COMPONI 
ONENT, AND THE INTERF 




SOCIA 
COMP 






CO 




< 



o 



CM 



00 



o 

00 



LU 
CO 
D 

< 
O 



O 

o 



O 
LU 

CO 
O 

z 
g 

i- 

o 



LU 
> 
LU 
O 
LU 



LU 
X 
I- 

o 
I- 

cd 

z 

Q 

cr 
o 
o 
o 
< 



z 
g 

o 

Li- 

LU ? 



H 
O 
LU 

—3 

CO 

O 
z 
g 



o o 

CO z 

^ LL 

LU 



LU 

z 

LU 
CD 



o 




H 




CD 




z 




Q 




QL 


Z 


O 


o 


O 




O 




< 




H 


a: 


Z 


O 


LU 


LL 


Z 


z 


o 




D_ 


H 




O 


o 


LU 

~5 


o 


GO 


— 1 


O 


ICA 


NO 


X 

CL 


h- 




o 




z 


CD 


FU 


< 


LU 


LU 


X 


t 


1- 


LU 




Z 




LU 




O 





o 




H 




o 




z 




Q 




COR 


ION 


o 


\— 


ENTAi 


ORMA 


INO 


INF 




H 




O 


o 


LU 


a 


—) 
CO 


LU 

o 


o 




z 


i 


o 




1- 


INTE 


UNC 


z 


LL 


< 


LU 


M"E 


HI 


c£ 

LU 




z 




LU 




O 





X 
CL 

CD 

LU 
X 
H 

Z 
LU 
Z 

o 

CL 



LU 
Z 

o 

Q_ 

o 
o 

UJ 

o 

2 

LU 



o 

O LU 



H 

a. 

q: 
o 

CO 
LU 
X 

h- 

LU 

o 
o 

CO 
CO 

< 



X 
H 
Q 
Z 

< 



LU 
Z 

o 

CL 

o 
o 



CM 



o 



PROCESSING 
UNIT 



COMPUTER 



523 



System 
Memory 



RAM 



ROM 




Interface 



Hard Drive 



33 



Interface 



534 



Floppy Drive/ 




DISK 





Interface 



Video 
Adaptor 



548 



CD-ROM Drive 




DISK 





546 



Serial 
Port 
Interface 



Network 
Adaptor 



MODEM 



554 



53 



^0_per_ating_Systern ]^ g35 
r/App/cijron//_^ 536 



-528 
529 

530 
531 



MONITOR 



542 



L 



-547 



540 



KEYBOARD 



MOUSE 



55 



WAN 



LAN 



551 



549 



REMOTE 
COMPUTER 



Memory 
Storage 



FIG. 13 



550 



MSFT Docket No. 147164.1 



PATENT 



Combined Declaration and Power of Attorney 

(original, design, national stage of pct) 

As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name, I believe I am the original, first 
and sole inventor (if only one name is listed below) or an original, first and joint inventor (if plural names are listed 
below) of the subject matter which is claimed and for which a patent is sought on the invention 
entitled: FUNCTION OBJECTS 

the specification of which: 

(a) X is attached hereto. 

(b) was filed on as Serial No. 0 / or 

Express Mail No. , as Serial No. not yet known, and was amended on 

(if applicable). 

(c) was described and claimed in PCT International Application No. filed 

on and amended under PCT Article 19 on (if any). 

I hereby state that I have reviewed and understand the contents of the above identified specification, including the claims, 
as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to patentability in accordance with Title 37, Code of 
Federal Regulations '1.56(a). 

PRIORITY CLAIM 

I hereby claim foreign priority benefits under Title 3 5 , United States Code, '119 of any foreign application(s) for patent or 
inventor's certificate or of any PCT international application(s) designating at least one country other than the United 
States of America listed below and have also identified below any foreign application(s) for patent or inventor's 
certificate or any PCT international application(s) designating at least one country other than the United States of 
America filed by me on the same subject matter having a filing date before that of the application(s) of which priority is 
claimed. 

(d) X no such applications have been filed. 

(e) such applications have been filed as follows. 

EARLIEST FOREIGN APPLICATION(S), IF ANY FILED WITHIN 12 MONTHS 
(6 MONTHS FOR DESIGN) PRIOR TO THIS U.S. APPLICATION 

COUNTRY APPLICATION NUMBER DATE OF FILING PRIORITY CLAIMED 

(day, month, year) UNDER 35, USC 1 1 9 

Yes No 



Yes No 



Yes No 



ALL FOREIGN APPLICATION(S), IF ANY FILED MORE THAN 12 MONTHS 
(6 MONTHS FOR DESIGN) PRIOR TO THIS U.S. APPLICATION 



D-OUS-3 FRM (1/93) 



Page 1 of 3 



MSFT Docket No. 147164.1 



PATENT 



Power of Attorney 

As a named inventor, I hereby appoint the following attorney(s) and/or agent(s) to prosecute this application and transact 
all business in the Patent and Trademark Office connected therewith. (List name and registration number) 

Himanshu S. Amin, Reg. No. 40,894; Gregory Turocy, Reg. No. 36, 952; 
Christopher P. Harris, Reg. No. 43,660; Eric M. Highman, 
Reg. No. 43,672; and Gary J. Pitzer, Reg. No. 39,334. 

Katie E. Sako, Reg. No. 32,628 and Daniel D. Crouse, Reg. No. 32,022. 
The undersigned to this declaration and power of attorney hereby authorizes the U.S. attorney(s) named herein to accept 
and follow instructions from: 

Name(s) of authorized representative(s) . 

Address „ 



as to any actions to be taken in the Patent and Trademark Office regarding this application without direct communication 
between the U.S. attorney(s) and the undersigned. In the event of a change in the person(s) from whom instructions may 
be taken, the U.S. attorney(s) will be so notified by the undersigned. 

Send Correspondence To: Direct Telephone Calls To: 

(name and telephone number) 

Himanshu S. Amin 

AMIN, ESCHWEILER & TUROCY, LLP Himanshu S. Amin 

24 th Floor, National City Center 

1900 East 9 TH Street (216) 696-8730 

Cleveland, Ohio 44114 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with knowledge that willful 
false statements and the like are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the 
United States Code, and that such willful false statements may jeopardize the validity of the application or any patent 
issued therein. a \ \ y< 

Full name of sole or first inventor, if anv £ * Nagender P. Vedula . 

Inventor's signature: j^^Tj^* . — 

Date: kf~ I 2- t *2jD&Q Country of Crfizenship: India _ 

Residence: * BothelL Washington 

Post Office Address: 20414 SE 2 nd Avenue 

BothelL Washington 98012 



Full name of second niij flint ^ygatorjf a ny: Dharma K. Shukla 

Inventor's signature: 




Date: QfP4^ \ Country of Citizenship: India 



Residence:, * _ Bellevue, Washington 

Post Office Address: : : 15209 NE 16 th Place 

Bellevue, Washington 98007 



Check For Any Of The Following Added Page(S) Which 
Form A Part Of This Declaration 

X Signature for third and subsequent joint inventors. Number of pages added 
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Full name third inventor, if any: 



Inventor's signature^ 
Date: 9//A/C7^ 



Aditya G. Bhandarkar 



.Coimfry of Citizenship 



India 



Residence: 

Post Office Address: 



Bellevue, Washington 



4777 148 m Avenue, NE 



Bellevue, Washington 98007 



X This declaration ends with this page. 
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